Python + Selenium自动化测试
全部标签 我正在尝试通过向我的SessionsController发出POST请求来测试是否有人能够登录我的站点。我在几个地方看到过这种推荐方式:it'mustbeabletosigninauser'douser=create(:user)post:create,format::js,user:{email:user.email,password:user.password,remember_me:0}assert_response:success@controller.current_user.must_equaluserend但是这个测试是不正确的。调用@controller.current
我正在运行Ubuntu16.04,我正在尝试使用chromedriver在ruby中运行headlessChrome浏览器。我已经使用theseinstructions在Ubuntu上安装了chromedriver然后我通过rubyirb控制台运行它:require'selenium-webdriver'options=Selenium::WebDriver::Chrome::Options.newoptions.add_argument('--headless')@driver=Selenium::WebDriver.for(:chrome,options:options)T
我想自动化这个场景。用户A将一个项目分配给用户B,用户B收到一条警告消息。为此,我想用不同的帐户启动两个不同的浏览器来测试这种交互。有可能这样做吗?如果是,如何? 最佳答案 看起来这个问题已经在我的示例代码中得到了回答:http://stackoverflow.com/questions/213430/selenium-rc-run-tests-in-multiple-browsers-automatically。firefox=Selenium::SeleniumDriver.new("localhost",4444,'*fire
我正在齐心协力围绕Rspec进行研究,以便转向更多的TDD/BDD开发模式。但是,我还有很长的路要走,并且在一些基础知识上苦苦挣扎:比如,我究竟什么时候应该使用模拟/stub,什么时候不应该?以这种情况为例:我有一个Site模型has_many:blogs和Blog模型has_many:articles。在我的Site模型中,我有一个回调过滤器,它为每个新站点创建一组默认的博客和文章。我想测试该代码,所以这里是:describeSite,"whencreated"doincludeSiteSpecHelperbefore(:each)do@site=Site.createvalid_s
背景:我有一组针对我的Rails3应用程序运行的Capybara集成测试。对于测试套件的其他部分,我使用的是Rspec。我的MacOSX开发机器上有一个selenium2.6.0独立服务器集线器。java-jarselenium-server-standalone-2.6.0.jar-rolehub我正在运行多个虚拟机,每个虚拟机都通过一个selenium节点连接到集线器:java-jarselenium-server-standalone-2.6.0.jar-rolewebdriver-hubhttp://0.0.1.12:4444/grid/registerport5555-bro
背景使用Paymill'ssubscriptionbilling开发应用程序特色。利用Rubywrapper,我创建了一个PaymentProvider类和规范如下。问题如何使测试支付失败?(例如卡被拒绝,或卡在未来的订阅付款中过期)Stripewouldletmedothisusingspecialcardnumbers但似乎没有针对Paymill的任何此类文档(英文)。payment_provider.rbclassPaymentProviderPaymill.api_key=ENV['PAYMILL_PRIVATE_KEY']defself.start_new_subscript
我有一个可以像这样配置的模块:moduleMyModulemattr_accessor:setting@@setting=:some_default_valueendMyModule.setting=:custom_value我正在使用RSpec测试不同的配置选项,发现设置在不同的测试之间保持不变,因为它们是类变量。在RSpec测试之间重新加载和重新初始化模块的最佳方法是什么? 最佳答案 我想到了这个解决方案:describeMyModuledobefore:eachdo#RemovestheMyModulefromobject-s
所以,我已经开始创建一些使用SeleniumRC的Ruby单元测试。直接在浏览器中测试我的网络应用程序。我正在使用Selenum-Client对于ruby。我已经为所有其他selenium测试创建了一个基类来继承。这会创建许多SeleniumDriver实例,并且会在每个实例上调用所有缺少的方法。这实质上是并行运行测试。其他人是如何实现自动化的?这是我的实现:classSeleniumTest这行得通,但如果一个浏览器失败,整个测试就会失败,并且无法知道它在哪个浏览器上失败。 最佳答案 你试过了吗SeleniumGrid?我认为它创
如何让我的Rails应用程序的测试以随机顺序执行?有没有使用rake的简单解决方案? 最佳答案 给你,在lib/tasks/tasks.rb中定义它namespace:testdonamespace:randomizedodesc"Randomizetests"Rake::TestTask.new(:all=>"db:test:prepare")do|t|t.libs运行:raketest:randomize:all请记住,在文件内测试仍将按照它们出现的顺序执行。我猜你可以猴子补丁测试单元来考虑到这一点。
当你使用带自动缩进模式的irb时,end语句会额外缩进一层deffoo...end而不是显示普通的缩进约定:deffoo...end因为你不能提前告诉irb你要在下一行越狱一个关卡。这个问题已经在其他地方得到解决,比如here或here,但都没有给出令人满意的答案。他们只是建议放弃。但是,如果我们可以最低限度地覆盖一些irb方法,以便自动缩进将插入空格而不是在提示区域,而是在您键入的行的开头,那么默认情况下,irb仍将插入空格,但我们将能够用退格键删除一些空格。这可能吗?或者,如果这不现实,那么是否可以让irb从屏幕上删除最后一行,并在您在包含end的行上按Enter后立即以适当的缩进